-
Notifications
You must be signed in to change notification settings - Fork 92
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Switch to overlay webviews for notebooks #5829
Conversation
…e logic a bit better.
- Added NotebookVisibilityProvider to manage editor visibility state. - Introduced observable for tracking editor visibility in PositronNotebookEditor. - Updated setEditorVisible method to set visibility state. - Modified webview mounting logic to conditionally mount based on visibility.
E2E Tests 🚀 ? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I checked out the branch and played around with it a bit and found a few issues.
In a notebook with two cells:
import hvplot.pandas
import pandas as pd
import plotly.express as px
df = px.data.iris()
fig = px.scatter(df, x='sepal_width', y='sepal_length')
fig
-
The plot seems to be placed over the cell selection border, see the section in the red box:
-
The plot remains if I switch between two notebooks:
Screen.Recording.2024-12-19.at.16.59.25.mov
-
There's a similar issue when showing/hiding the bottom pane with Cmd+J:
Screen.Recording.2024-12-19.at.17.00.58.mov
Currently this experimental notebook doesn't have running animation as well as cell execution completion info. Hope these features will come soon |
@ntluong95 , see #5495 and there is a simple running animation (a pulsing border around the cell executing). Feel free to make a new issue for the cell execution animation with ideas about it - it's a tricky problem and we'd love your input! Also reacting to the other issue can help us prioritize! Currently we're focusing on the underpinnings of the current notebooks to get them rock solid before making a big push on these experimental notebooks. |
@seeM I couldn't reproduce 1 locally but the others should be fixed. Let me know if you still have the problem with overlap. |
…and releasing the webview
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It unfortunately isn't showing at all now:
Screen.Recording.2025-01-02.at.08.55.11.mov
Happy to merge this now since it's already behind a feature flag, and do any additional work once you're back.
E2E tests pass too: https://github.com/posit-dev/positron/actions/runs/12578730237.
Addresses #5491
This PR changes how we render html output in notebooks 2.0 by switching to overlay webviews instead of standard ones.
The reason for this switch was that there is no way to preserve the content of the webview across visibility changes with standard webviews. This means we would have to fully re-render every output every time the user switched to the notebook view.
One benefit of this switch is we were able to remove all the logic surrounding different webview types being returned from the various webview services, simplifying the API a good bit.
QA Notes